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Background Of The Invention 

1. Technical Field. 

The invention relates to configuration of a kitchen or other household appliance 
network. More particularly, the invention relates to an intelligent controller that is able to 
communicate with and relay information between intelligent household appliances and at 
least one device in an external network. 

2. Related Art. 

Currently, household appliances such as coffeemakers and ovens are independent 
and when used require manual programming. Some appliances, such as a coffeemaker, 
may be configured to have timers for turning the appliance on and off. The programming 
of the timers in these appliances is accomplished at the appliance using manual controls 
or buttons. Further, it is often impossible to change the configuration or programming of 
an appliance, such as the auto off timer in a coffeemaker, once the appliance has left the 
factory. 

Another problem with household appliances is for every product cooked, such as 
a frozen dinner, the user must set the cooking temperature and the time. Dinners may be 
ruined or homes burned down because of a user erroneously setting the wrong cooking 
time or temperature. Prior approaches to resolving the erroneous setting problem have 



included cookbooks that contain bar coded instructions associated with encoded 
instructions for setting cooking time and temperature. Such appliances include a bar code 
reader to read the cookbook's bar code associated with a user-selected recipe. However, 
as new products are introduced in the supermarket or new recipes are created, the 
5 cookbooks must be physically updated or replaced. 

Furthermore, it is not uncommon for appliances to have clocks that must be 
initially set and reset after a power outage. Due to the quality of the components in an 
appliance clock, it is rare when all clocks on respective appliances match and do not drift 
apart. After some period of time, the clocks on some of the appliances will have to be 
C3 10 adjusted if a user desires all clocks to report the same time. Furthermore, clocks have to 
^3 be reset twice a year in the United States for changes to or from Day Light Savings Time 

Jjj^ and may also have to be reset following a power outage. 
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Thus, there is a needed in the art for an approach to set cooking time and 
temperature that is easy to updated while enabling coordination of data between multiple 



Summary 

An intelligent controller having a modem communicates with a remote database 
that has a plurality of user profiles. A user profile in the database is configurable via a 
20 device for displaying a user interface , such as a personal computer accessing the World 
Wide Web with web pages for an intelligent controller and other appliances. The 
intelligent controller receives user profile information via the modem from the database. 
The user profile may include, for example alarm clock settings, radio stations, and recipe 
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programs for the appliances. A power line communication unit in the intelligent 
controller allows communication of data received by the modem via an external network 
to other appliances over a local network communication link, such as the alternating 
current (AC) wiring of a home, a wireless connection, or the in home telephone wires. 

A clock is periodically synchronized to a time message that the web server 
transmits to the intelligent controller and distributed by the power line communication 
unit to appliances that are capable of receiving the power line communications. The 
synchronization automatically corrects for time changes and assures all clocks report the 
correct time. The user profile also contains a time zone identifier that enables the clocks, 
including the clock in the intelligent controller, to report the proper time for a specified 
time zone. The intelligent controller may also have an associated radio with radio preset 
radio stations being programmed in the user profile and received at the intelligent 
controller via the modem. The radio along with the clock may function as an alarm clock 
radio having an alarm associated with each day of the week and each alarm being 
independently settable to a "buzz" or any of the programmed radio stations. 

A coffeemaker having a local network communication link may be one of the 
networked appliances. The coffeemaker may receive time, brew time, warming time, and 
turn on/off time configuration information from the intelligent controller. The 
coffeemaker may also communicate its status to the intelligent controller allowing a user 
to know at a remote location if the coffeemaker needs to be set up for brewing, coffee is 
brewing or ready. Similarly, a breadmaker having a local network communication link, a 
display and bar code reader may be one of the networked appliances. The breadmaker is 
able to receive bread making recipe programs from the intelligent controller for storage in 



local memory. A user upon scanning or otherwise inputting a unique product code, such 
as a universal product code (UPC), provided with a package such as a bread mix or cake 
mix configures the cycles of the bread machine. A cycle typically includes a mixing 
period, dough rising period, baking period, and warming period. 

A microwave oven and a non-microwave type oven (for example, gas oven, 
electric oven, convection oven, or Ultravection™ oven) may be among the associated 
other appliances within the network. Each such oven would have a local network 
communication link and receiving recipe information from the remote database via the 
intelligent controller. The recipe information is stored in their respective memories. 
Each oven may also have a bar code reader for reading UPCs that results in the 
microwave oven or heating element type oven being configured for cooking the scanned 
product. The user may also be guided via a display screen through the preparation of the 
product 

If the input unique product code is unknown (i.e. not present in the memory of the 
appliance), the appliance may communicate the product code to the intelligent controller. 
The intelligent controller could then transmit the product code to the remote database as 
an unidentified product code. Later, a recipe program associated with the "unknown" 
product code may be transmitted back to the intelligent controller for further transmission 
to the original reporting appliance. The original reporting appliance then saves the recipe 
in memory. 

Other systems, methods, features and advantages of the invention will be or will 
become apparent to one with skill in the art upon examination of the following figures 
and detailed description. It is intended that all such additional systems, methods, features 



and advantages be included within this description, be within the scope of the invention, 
and be protected by the accompanying claims. 

Brief Description Of The Figures 

The components in the figures are not necessarily to scale, emphasis instead being 
placed upon illustrating the principles of the invention. In the figures, like reference 
numerals designate corresponding parts throughout the different views. 

FIG. 1 is a diagram of an intelligent controller in communication with a device 
capable of displaying a user interface via a modem and other appliances via a local 
network communication link in accordance with an embodiment of the invention. 

FIG. 2 is a diagram of the intelligent controller in communication with the web 
server and web device through a PSTN of FIG. 1 . 

FIG. 3 is a block diagram of the intelligent controller of FIG. 2. 

FIG. 4 is a web page to select preset radio stations for the intelligent controller via 
the device capable of displaying a user interface of FIG. 2. 

FIG. 5 is a web page to set alarms and radio station via the device capable of 
displaying a user interface of FIG. 2. 

FIG. 6 is a web page to enter current stocks via the device capable of displaying a 
user interface of FIG. 2. 

FIG. 7 is a web page to select pre-mix breadmaker recipe programs via the device 
capable of displaying a user interface of FIG. 2. 

FIG. 8 is a web page to select oven recipe programs via the device capable of 
displaying a user interface of FIG. 2. 



FIG. 9 is a web page to configure the coffeemaker settings via the device capable 
of displaying a user interface of FIG. 2. 

FIG. 10 is a web page to select microwave recipe programs via the device capable 
of displaying a user interface of FIG. 2. 

FIG. 11 is a block diagram of the coffeemaker with a local network 
communication unit of FIG. 1. 

FIG. 12 is a block diagram of the breadmaker with a local network 
communication link of FIG. 1. 

FIG. 13 is a block diagram of the microwave oven with a local network 
communication link of FIG. 1. 

FIG. 14 is a block diagram of the oven with a local network communication link 
of FIG. 1. 

FIG. 15 is a flow chart of an intelligent kitchen process in accordance with an 
embodiment of the invention. 

FIG. 16 is a flow chart of the process of the intelligent controller interacting with 
the coffeemaker in accordance with an embodiment of the invention. 

FIG. 17 is a flow chart of the process of a code being scanned at an appliance in 
accordance with an embodiment of the invention. 

Detailed description of the exemplary embodiments 
Reference is now made in detail to an embodiment of the present invention, an 
illustrative example of which is depicted in the accompanying drawings, showing an 
intelligent kitchen. In FIG. 1, a diagram of an intelligent controller 102 in 
communication with a web server 104 via a modem and other appliances by a power line 



communication unit is shown. In an alternate embodiment, radio frequency (RF) units 
may link the intelligent controller 102 and appliances 116-122 with a wireless link. In 
yet another embodiment, power line communication units provided a wired connection 
between the intelligent controller 102 and appliances 116-122 and RF units provide a 
second or redundant path between the intelligent controller 102 and appliances 1 16-122. 
In the alternate embodiments, the wired connection may be over CAT-3, CAT-5, or even 
fiber optical cables. The intelligent controller 102 may have a display 106 and control 
surfaces 107, such as push buttons and knobs. 

The modem in the intelligent controller 102 is connected to a RJ-11 telephone 
jack 108. The intelligent controller 102 at periodic times uses the modem to initiate a 
data call through the PSTN 110 to a remote database 103. The remote database 103 
contains data that is accessed by the server 104 and sent to the device capable displaying 
a user interface 112. An example of a remote database 103 is a database accessed by a 
web server upon a web page in a web browser either requesting or entering data. A 
device capable of displaying a user interface 112, such as a personal computer having 
another modem is also connected to via an RJ-11 telephone jack 114 and connected by 
PSTN 1 10 with server 104. The web device 1 12 communicates with the server 104 over 
an Internet Protocol connection. In an alternate embodiment, the intelligent controller 
102 may connected through an internet service provider and may even use a cable 
modem or DSL router to connect with the internet. In yet another embodiment, a 
different communication protocol may be used by the device 112 to communicate with 
server 104. 




The intelligent controller 102 is also connected to the alternating current (AC) 
home wiring by a power line communication unit communicating through a cord that is 
plugged into an AC outlet 114. The power line communication unit is able to 
communicate with other similarly equipped appliances such as coffeemaker 116, 
5 breadmaker 118, microwave oven 120, and conventional type oven 122. Each appliance 
1 16-122 has an associated power line communication unit that communicates through an 
AC outlet 124-130 for two-way communication between the intelligent controller 102 
and the appliances 1 16-122. Examples of power line communication units include X-10, 
CEBus and POWERBUS power line communication units. 

10 The power line communications between the intelligent controller 102 and the 

appliances 116-122 may be used to synchronize of all of the appliance clocks with the 
internal clock of the intelligent controller 102. In turn, the intelligent controller 102 may 
have an internal clock that is periodically synchronized by communication with the 
remote database 103 located on server 104. In one embodiment, the remote database 103 

15 maintains accurate time by receiving a timing signal from an atomic clock. In an 
alternate embodiment, a GPS clock may provide an accurate time signal to the server 
104. In another embodiment, a separate time server connected to an accurate clock or 
GPS clock may supply time to the network. 

The coffeemaker 116 receives programming for when to turn on from over the 

20 power line via the intelligent controller 102. The coffeemaker 116 may periodically 
and/or randomly report its state to the intelligent controller 102, where it maybe 
displayed. If an "on" time is set, for instance, then the coffeemaker 1 16 may report to the 
intelligent controller that it is not ready to brew. Once the user places water and coffee 
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grounds in the coffeemaker 116, the user presses a button on the coffeemaker 116 to 
place the coffeemaker 116 in a "ready to brew" state. Alternatively, coffeemaker 116 
may have sensors to determine whether supply water and coffee grounds are available. 
The coffeemaker 116 having informed the intelligent controller 102 that the coffeemaker 
is in the "ready to brew" state then may display a ready to brew symbol in the display 
1 10. When the programmed time occurs, the coffeemaker 116 starts to brew the coffee 
and may notify the intelligent controller 102 that it is in the brewing state. The intelligent 
controller 102 may, in turn ,display a brewing symbol on its (optional) display. 

When the coffeemaker finishes brewing, it may notify the intelligent controller 
102 that the coffee is ready. The intelligent controller 102 then may display, a coffee is 
ready symbol. The coffeemaker turns off automatically after a predetermined time 
period. It may also be turned off manually by a user pushing an off button. In either 
event, the coffeemaker may inform the intelligent controller 102 of the state change. The 
intelligent controller 102 may then report via its display that the coffeemaker is not ready 
to brew. Thus an advantage is achieved by having the intelligent controller 102 remotely 
display the state of the coffeemaker 1 16. Further, the time is correctly set and maintained 
by synchronization with the time maintained by the intelligent controller 102. 

The breadmaker 118, microwave oven 120 and conventional oven 122 may each 
have a respective bar code reader 130-134. The bar code readers enables the user of 
appliances 118-122 to scan a unique product code, such as the universal product code 
(UPC) located on a food container. Alternatively, the appliances may be equipped with 
control surfaces, such as push buttons or switches, that allow a user to manually input the 
code. This may be used to make the appliances less expensive or where a bar code reader 



is broken or perhaps not purchased with the appliance. The appliances 118-122 then 
attempt to identify a recipe program associated with the input product code. If the recipe 
program is found in local memory, then the appliance is configured by the execution of 
the recipe program. Thus, an advantage is achieved by being able to configure the 
appliances 118-122 for different types and manufactures of consumer food products. 
Further the risk of incorrectly preparing the food products is reduced because of less 
human interaction during the cycle programming of the appliances 1 18-122. 

Turning to FIG. 2, a diagram of the intelligent controller 102 in communication 
with the web server 104 and web device 1 12 through the PSTN 1 10 of FIG. 1 is shown. 
The web server 104 has a database 202 of user profiles with at least one user profile 204 
associated with each intelligent controller. The user profile 204 is periodically pushed 
down to an associated intelligent controller 102 along with time synchronization data and 
updated user selected data, such as news 212, stock prices 214 and weather reports 216. 
In an alternate embodiment, time synchronization data and updated user selected data 
may be pulled down by the intelligent controller 102 from the web server 104. The user 
selected data is sent from the web server 104 through the PSTN 1 10 to be received via 
modem 206 at the intelligent controller 102. The controller 210 stores the user-selected 
data (news 212, stock prices 214 and weather reports 216) into memory 208. The user- 
selected data stored in memory 208 may then be displayed by the controller 210 on 
display 218 along with time information. 

The user profile 204 stored in the database 202 located on the web server 104 also 
contains configuration data, such as time zone, user-selected preset radio stations, alarm 
times and settings ("buzz" or a radio station). The alarm times 220 and radio stations 221 
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configuration data is stored by controller 210 in memory 208 when periodically pushed 
down to the intelligent controller 102 from the web server 104. Miscellaneous data, such 
as recipe program updates, new recipe programs, other text or programs may be received 
by the intelligent controller 210 and stored in memory 208 or as appropriate 
miscellaneous memory 223. Data stored in memory 208 may also be transmitted to and 
received from other appliances through a local network communication link 220. 

The user profile 204 is configurable via a web browser 222 being executed on the 
web device 1 12 connected by an Internet Protocol connection through PSTN 1 10 to web 
server 104. In particular, the web browser 222 accesses configuration web pages 224 that 
may be associated with the intelligent controller 102 and other appliances 116-122. A 
time web page 226 is presented to a user of the web device 1 12 that allows a user to enter 
the zip code where the intelligent controller 102 will be located in operation. In other 
embodiments the time web page 226, may be implemented as input fields on another web 
page, such as a user information web page 234. The zip code is then used by a program 
on the web server 104 to identify possible radio stations and time zones. In other 
embodiments, the user may select the time zone and city where the intelligent controller 
102 is located. Further, the time web page 226 may be used to configure the clock 
function, set alarm web page 228. Other web pages that may be configured include stock 
selection web page 230, program radio stations web page 232, user information web page 
234, web pages for selections of recipe programs for a oven 236, breadmaker recipe 
program selection web page 238, coffeemaker programming web page 240, recipe 
program selection web page for the microwave oven 242 and recipe program selection 
pages for other appliances. 



Each web page communicates with the web server 104 and may result in the user 
profile 204 in the database 202 being configured or updated. Changes in the user profile 
204 are periodically transmitted between the intelligent controller 102 and the web server 
104, preferably by pushing down the data (whole user profile or just the changes in the 
user profile), at predetermined intervals. Thus, the ability to change or update programs 
associated with the user profile is achieved by downloading the changes or updates to 
appliances 1 16-122 via the intelligent controller 102. 

In an alternate embodiment, the web server 104 may contact the intelligent 
controller 102 and send the data contained in the user profile 204 to the intelligent 
controller 102 at periodic intervals. In yet another embodiment, the web server may 
contact the intelligent controller 102, upon configuration of the intelligent controller 102 
and/or upon a change being made to the user profile 204. Similarly, in another alternate 
embodiment, the intelligent controller 102 may synchronize with the web server 104 and 
user profile 204 upon a predetermined action occurring. Examples of such actions 
include; a user physically pressing a button to cause synchronization, new appliances 
being detected on the power line, or receiving a "unknown unique product code" message 
from an appliance. 

INTELLIGENT CONTROLLER 

In FIG. 3, a block diagram of the intelligent controller 102 of FIG. 2 is shown. 
The intelligent controller 102 has a controller 210 that is connected by a bus 302 to the 
modem 206, the memory 208, and the local network communication link 220. The 
intelligent controller 102 may also include the display 218, a radio 304, a plurality of 
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input controls 306, and a real-time clock 308. The controller 210 is preferably a 
microprocessor, but in an alternate embodiment may be a reduced instruction set chip 
(RISC) processor, micro-controller, digital circuits functioning as a controller, analog 
circuits functioning as a controller, a combination of analog and digital circuits 
functioning as a controller, or a digital signal processor. 

The modem 206 is preferably a low speed 300-14,400 kbps internal modem and is 
a network interface to PSTN 110. Among other potential advantages, the use of a low 
speed modem keeps the cost of the system lower. In an alternate embodiment, a higher 
speed modem or network interface may be used. In yet another alternate embodiment, an 
external network interface may be used to access the PSTN 110 and connect to the 
intelligent controller 102 via an external bus such as a serial bus, SCSI bus, or universal 
serial bus (USB). The modem 206 may also make a connection to the external network 
by wireless means, such as wireless Ethernet connection, 900 MHz in home network, or 
cellular connection. 

The radio 304 is configurable by data received via the modem 206 by the 
controller 210. Such configuration information may include preset radio stations for 
among other available mediums both the AM and FM radio bands that are stored in 
memory 208. The radio 304 can be activated either by one of the plurality of input 
controls 306 or by the controller 210 in response to the real time clock 308. A radio 
signal is received by an antenna (not shown) among other available mediums such as 
streaming data. In an alternate embodiment, the radio 304 may included a weather alert 
radio in place of or in addition to the radio 304. 
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The display 218 is able to display text and low-resolution graphics. The display is 
controlled by a display controller 310 that is in communication with memory 208 and 
controller 210. Alternatively, display controller 310 may be integrated with controller 
210 or display 218. The display 208 is a monochrome liquid crystal display (LCD). In 
an alternate embodiment, a high-resolution display may be used. Further, a color display 
may be used in yet another embodiment. In other embodiments, other types of displays 
that are capable of displaying data may be used, including for example cathode ray tubes 
and plasma displays. The display may even be a touch screen that combines the plurality 
of input controls 306 with display 218. 

A real-time clock 308 having a oscillator is connected to the controller 210. The 
real-time clock 308 is a digital chip that is programmable by the controller 210 in 
response to a synchronization signal (time message) being received at modem 206. The 
real-time clock 308 is preferably only accurate enough to maintain time for a period of 
approximately two weeks, thus allowing for greater variances in component quality. A 
network indicator may be provided on the display 218, to indicate if a synchronization of 
real-time clock 308 has occurred within a preceding two-week period. Thus, an 
advantage is achieved by maintaining the correct time by synchronization of the real-time 
clock 308 with the correct time maintained at the web server 104. Alternatively, a more 
accurate real time clock could be utilized, thus reducing the need for synchronization 
between the real-time clock 308 and the server 104. 

The memory 208 is preferably a combination of random access memory (RAM), 
such as dynamic random access memory (DRAM), synchronous dynamic random access 
memory (SDRAM), or other types of read/write memory, and of read only memory 
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(ROM), such as programmable read only memory (PROM), electrically erasable 
programmable read only memory (EEPROM). In an alternate embodiment, the memory 
may include external semi-permanent memory, such as magnetic disk (hard disk, 
removable hard disk, floppy disk), optical disk (CD-RW) or external permanent memory 
5 (CD-R and DVD-R). The memory 208 is divided into a program portion that controls the 
operation of the intelligent controller 102 and a data portion that maintains configuration 
data and variables used and manipulated by the controller 210 upon execution of a 
program. 

The local network communication link 202 transmits a carrier signal that is 

Q 10 capable of transporting data between the intelligent controller 102 and devices over a 

C3 

Q communication link. In a preferred embodiment, local network communication link 202 

I* 

?U is a power line communication transceiver that sends and receives signals over a home's 

in 

W AC wiring that electrical appliances receive power. Thus, the power line communication 

[T unit is shown both a power supply for the intelligent controller 102 and a communication 

C3 

l A 1 5 unit that enables two-way communication with other appliances that share the AC wiring, 

h 

}* but may be implemented separately. Examples of such power line communication 

approaches include; X-10, CEBUS, and POWERBUS by Domosys Corp. In an alternate 
embodiment, the power line communication unit 202 may be replaced with a wireless RF 
unit that establishes a wireless connection between the intelligent controller 102 and other 
20 appliances. 

The minimum functionality required in the intelligent controller 102 is to convert 
data received over an external network to the internal network enabling communication 
between the internal network and the external network. The communication path to the 
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external network (e.g. Internet) is often costly to keep active and requires telephone 
resources that are only periodically available in a home. Therefore, the intelligent 
controller 102 acts as a temporary storage unit in the transmission of data. For example, 
if an appliance scans a product code that is unknown to that appliance, a message is sent 
5 to the intelligent controller 102 for future transmission to the web server 104 upon 
synchronization. Additional functionality is added to the intelligent controller 102 for the 
convenience of the user, such as the display 218, radio 304 and clock 308 with a human 
perceptible time indicator such as display 218, tones, synthesized voice, light emitting 
diodes forming a display). 

10 Another slave intelligent controller (not shown) may be in communication with 

the intelligent controller 102 and act as a second input/display device. The slave 
intelligent controller has a controller, display, memory, power line communication unit, 
and plurality of control surfaces. In such a system, information displayed on the 
intelligent controller 102 is mirrored on the slave intelligent controller. The plurality of 

15 buttons 306 on intelligent controller 102 is also mirrored on the slave intelligent 
controller. Thus, a person may have one intelligent controller 102 and a plurality of slave 
intelligent controllers in different rooms of a home. Further, the slave intelligent 
controller may contain another radio that is separately programmable from the radio in 
the master intelligent controller. Similarly, the slave intelligent controller may have an 

20 alarm clock that is separately programmable from the alarm clock in the master 
intelligent controller. In another embodiment, the intelligent controller 102 does not have 
a display 218 or plurality of button 306, rather the intelligent controller 102 relays the 
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information to be displayed to all the displays on the slave intelligent controller and 
receives input from the plurality of button on the slave intelligent controllers. 

CONFIGURATION WEB PAGES 
5 A remote computer may function as the device capable of displaying a user 

interface 1 12. The remote computer is likely a general-purpose computer system such as 
an IBM compatible, Apple, or other equivalent computer (using a processor that may 
selectively be an Intel, AMD, Cyrix, Motorola 68XXX or PowerPC series, Compaq 
Digital Alpha, Sun, HP, IBM, Silicon Graphics, or other type of equivalent processor) 

10 that, among other functions, allow a user to communicate with server 104 via a external 
network, such as the PSTN network. The network is any network that allows multiple 
computer systems to communicate with each other such as a Local Area Network (LAN), 
Storage Area Network (SAN), Wide Area Network (WAN) alternative Intranet, Extranet, 
or the Internet. Server 104 is preferably a general-purpose computer system such as an 

15 IBM compatible, Apple, Unix type workstation, or equivalent computer (using a 

processor that may selectively be an Intel, AMD, Cyrix, Motorola 68XXX or PowerPC 
series, Compaq Digital Alpha, Sun, HP, IBM, Silicon Graphics, or other type of 
equivalent processor) that may generate a user interface, responds to commands, and 
communicates with server 104. Of course, the device 1 12 and server 104 need not be the 

20 same type of general-purpose computer. Both remote computer and server 104 

preferably contain a network interface that allows for communication via a network. 
Network interfaces may selectively include hardware and any software capable of 
communicating with the network. Examples of the software would be any LAN, WAN, 
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SAN, alternative Intranet, Ethernet capable or Internet compatible software program such 
as Novell, Windows, Unix, Netscape Navigator, Microsoft Internet Explorer, Mosaic, 
UP.BROWSER, or similar. It should also be noted that the network could comprise the 
public telephone network with server 104 acting as a dial-up bulletin board and remote 
computer dialing in directly to server 104 via the telco network. 

Using a remote computer to operably connect to server 104 — in a well-known 
manner dependent upon the technology of network — the user will access the home page 
of web pages, and thus access to the various functions of the server 104 would be made 
via hyperlinks. Of course, while the present disclosure is being made in a HTML-type 
environment, use of this environment is not required as part of the present invention. 
Other programming languages and user-interface approaches may also be used to 
facilitate data entry and execute the various computer programs that make up the present 
invention. 

Information may be entered into the user interface for entry into a database 202 
residing on the server 104. The information may be input in conjunction with a variety of 
computer data entry techniques. In some instances, the information may be type-checked 
(i.e. character, integer, date, etc.), limited by "lookup table" constraints or completely 
freeform. A user enters a user identifier and the serial number of the intelligent controller 
102 into a web page. Upon actuation of the submit button (or similar action), the 
information entered in the different web pages populates the database entry (not shown) 
for each user. For new members this process may further involve the creation of a new 
database record. As a result, server 104 (or another general purpose computer or file 
server operably associated with server 104) stores the records in the database, the 
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computer programming methods and procedures for which are well-known to those of 
ordinary skill in the art. 

In FIG. 4, an example web page to select radio stations 232 at the web device of 
FIG. 2 is shown. A user of the device capable of displaying a user interface 1 12 accesses 
the server 104 and a user profile associated with the intelligent controller 102. The user 
supplies information relating to the operating location of the intelligent controller 1 02 
such as a zip code or enters time zone information in a time web page 226 and is then 
presented with other configuration web pages 224. The server 104 sends a web page 232 
to the device 1 12 for selection of the preset radio stations. In a preferred embodiment, 
the web page identifies the available radio stations 404 by their frequency 406, call sign 
408, city 410, and state 412. The user then selects 414 which of the stations should be 
pre-selected by placing a check in a box 416 associated with the desired station. The web 
page may also display the radio stations that have already been selected 418. As would 
be understood by those familiar with graphical user interface design, the particular 
placement of elements and user input techniques could be modified in view of this 
present disclosure without departing from the scope of the invention. Upon completion, 
the web page is transmitted to the web server 104 for processing and placement of the 
data into the users profile 204. 

Turning to FIG 5, an example web page to set alarms and radio station 226 at the 
web device 1 12 of FIG. 2 is shown. In this preferred approach, the user is shown the day 
of week 502 and is presented an input field for selected "on time" 504. If the intelligent 
controller includes a radio, then the alarm may have a wake-up station 506 set to a default 
"buzz" (i.e. no station) or may be set to one of the radio station presets using a page 
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similar to that of FIG. 4. Further, the user would then activate selected alarms by 
indicating in an input field 508 that the alarm is to be active. The user is able to review 
the current alarm settings by viewing the current alarm display 508 that is present on the 
web page 226. The changes that have just been made by a user may not be reflected in 
the current alarm display 508 until the alarm schedule is updated. Upon completion, the 
alarm schedule is updated and the data is transmitted to the web server 104 for processing 
and placement into the users profile 204. 

In FIG. 6, an example web page 230 to enter current stocks 230 at the web device 
112 of FIG. 2 is shown. A user may select the web page 230 to select stocks for 
inclusion in a portfolio tracker. The user is then presented with his current portfolio 
(initially empty) that includes stock symbols 606, company names 608 and the number of 
shares 610. The user is also presented with the options of selecting other web pages such 
as "Update Your Portfolio" 602 or "Add to Your Portfolio" 604. "Updating Your 
Portfolio" 602 enables a user to access a web page with input boxes for the number of 
shares. "Add to Your Portfolio" 604 accesses a web page for adding or deleting stocks 
from the portfolio. Upon completion, the data from web page 230 is transmitted to the 
web server 104 for processing and placement into the users profile 204. 

Turning to FIG. 7 an example web page 238 to select pre-mix breadmaker recipe 
programs at the device 112 of FIG. 2 is shown. The page may be made inaccessible to 
users who have not purchased an intelligent breadmaker 118. A user accesses the web 
page 238 from the web server 104 and selects the pre-mixed bread recipe programs that 
user desires to have downloaded to the breadmaker 118. Of course, it should be 
understood that the recipe programs shown are by way of example and not intended to 
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limit the invention. The name of the pre-mixed bread 702 is displayed along with an 
associated unique product codes, such as UPC 704. The user selects a pre-mixed bread 
recipe program 706 by placing a mark in an input box 708. The memory limitation of the 
breadmaker is reflected by the number of pre-mix bread recipe programs that may be 
selected and ultimately downloaded, twenty in the present example. In an alternate 
embodiment, more recipes may be downloaded if more memory is available or if 
compression techniques are used. In yet other embodiments, the selection of recipe 
programs occurs over time automatically with a predetermined number of the most recent 
used recipe programs being selected. The current selected pre-mix bread recipe programs 
will be displayed on web page 238 with checks in the selection input field 706. Upon 
completion, the web page 238 is transmitted to the web server 104 for processing and 
placement of the data into the user's user profile 204. 

In FIG. 8, an example web page 236 to select oven recipe programs at the web 
device 112 of FIG. 2 is shown. The page may be made inaccessible to users who have 
not purchased an intelligent oven. A user accesses the web page 236 from the web server 
104 and selects the oven recipe programs that the user desires to have downloaded to the 
oven. The names of the oven recipe programs 802 are displayed along with an associated 
UPC 804. The user selects a oven recipe program 806 by placing a mark in an input box 
808. The memory limitation of the oven is reflected by the number of oven recipe 
programs that may be selected and downloaded, 20 recipe programs in the present 
example. In an alternate embodiment, more recipe programs may be downloaded if more 
memory is available or if compression techniques are used. In yet other embodiments, 
the selection of recipe programs occurs over time with a predetermined number of the 
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most recent recipe programs being selected. The current selected oven recipe programs 
will be displayed on the web page 236 with checks in the selection input field 806. Upon 
completion, the data from web page 236 is transmitted to the web server 104 for 
processing and placement into the users profile 204. 

Turning to FIG. 9, an example web page 240 to configure the coffeemaker 
settings at the web device 112 of FIG. 2 is shown. The page may be made inaccessible to 
users who have not purchased an intelligent coffeemaker. Upon accessing the web page 
240 to configure the coffeemaker settings, the user is presented with a schedule for each 
day of the week 902. The user is shown the current "On Time" 904 and "Off Time 5 ' 906. 
The user is able to change the "On Time" 904 or "Off Time" 906 by accessing the 
appropriate input box 908 and 910 for example. The user is also shown the current brew 
schedule 912 for the coffeemaker. The brew schedule is updated by selection "Update 
Brew Schedule" 914 and the data is updated in the user profile 204 located in the 
database 202 located at the web server 104. Although the example of FIG. 9 shows only 
one setting per day of the week, it is contemplated that any or all days could have a 
plurality of "On Times" and "Off Times". 

In FIG. 10, an example web page 242 to select microwave recipe programs at the 
web device 112 of FIG. 2 is shown. The page may be made inaccessible to users who 
have not purchased an intelligent microwave oven. A user accesses the web page 242 
from the web server 104 and selects the microwave oven recipe programs to be 
downloaded to the oven. The name of the microwave oven recipe program 1002 is 
displayed along with an associated with a unique product code, such as UPC 1004. The 
user selects a microwave oven recipe program 1006 by placing a mark in an input box 
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1008. The memory limitation of the microwave oven is reflected by the number of 
microwave oven recipe programs that may be selected and downloaded, twenty in the 
present example. In an alternate embodiment, more recipe programs may be downloaded 
if more memory is available or if compression techniques are used. In yet other 
embodiments, the selection of recipes occurs over time with a predetermined number of 
the most recent used recipe programs being selected. The current selected oven recipe 
programs will be displayed on the web page 236 with checks in the selection input field 
1006. Upon completion, the data from web page 242 is transmitted to the web server 104 
for processing and placement into the users profile 204. 

COFFEEMAKER 

FIG. 1 1 is a block diagram of the coffeemaker 1 16 (also shown in FIG. 1) with a 
local network communication link 1106 of FIG. 1. In the preferred embodiment, 1 106 is 
a power line communication unit. The coffeemaker 1 16 includes a controller 1 102 that is 
operably connected to a bus 1104 that enables communication with a local network 
communication unit 1106, memory 1108, display 1110, a real-time clock 1112, and a 
heating element controller 1114. The heating element controller 1114 is able to 
electrically control the heating element 1116 and warming plate 1118. A plurality of 
buttons 1120, may also be present and in communication with the controller 1102 to 
enable manual configuration/operation of the coffeemaker 1 16. 

The controller 1 102 is a preferably a microprocessor. In an alternate embodiment 
controller 1 102 may be a reduced instruction set chip (RISC) processor, micro-controller, 
digital circuits functioning as a controller, analog circuits functioning as a controller, a 
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combination of analog and digital circuits functioning as a controller, or a digital signal 
processor. 

The display 1110 is a light emitting diode display and is able to display numbers 
(time) and human perceptible indicators such as graphics, text, light emitting diodes, light 
bulbs, audio signal, or even mechanical signal (i.e. flags or arms that are raised and 
lowered). The indicators indicate among other possibilities when the coffeemaker 1 16 is 
on, programmed, ready to brew, brewing, and coffee ready. In an alternate embodiment, 
the display 1110 may be a liquid crystal non-color display. In yet another alternate 
embodiment, a high-resolution display may be used. Further, a color display may be 
used in yet another embodiment. The display may even be a touch screen display that 
combines the plurality of buttons 1 120 with display 1 1 10 in an additional embodiment. 

The local network communication unit 1106 is a unit that transmits a carrier 
signal that is capable of transporting data between devices over the traditional home AC 
wiring that electrical appliances receive power from. Thus, the local network 
communication unit 1 106 is shown as both a power supply for the coffeemaker 1 16 and a 
communication unit that enables two-way communication with the intelligent controller 
102 that share the AC wiring. Examples of such power line communication approaches 
include; X-10, CEBUS, and POWERBUS by Domosys Corp. Of course, other local 
network interfaces could alternatively be substituted, such as wireless, cellular and 
telephone line network interface. 

The memory 1108 is preferrably a combination of random access memory 
(RAM), such as dynamic random access memory (DRAMs), synchronous dynamic 
random access memory (SDRAMs), or other types of read/write memory, and of read 



-24- 



only memory (ROM), such as programmable read only memory (PROM), electrically 
erasable programmable read only memory (EEPROM). In an alternate embodiment, the 
memory may include external semi-permanent memory, such as magnetic disk (hard 
disk, removable hard disk, floppy disk), optical disk (CD-RW) or external permanent 
5 memory (CD-R and DVD-R). The memory is 1 108 is divided into a program portion that 
controls the operation of the coffeemaker 116 and a data portion that maintains 
configuration data and variables used and manipulated by the controller 1102 upon 
execution of a program. 

In manual operation, the user may set the real-time clock 1 1 12 of the coffeemaker 
[* 10 via the plurality of buttons 1 120. The coffeemaker may be turned on or off by one of the 
it plurality of buttons 1120. Once turned on, controller 1102 in the coffeemaker 116 will 

y 

»y instruct the heating element controller 1 1 14 to automatically turn off the heating elements 

In 

iy after a short period of time (after coffee is made). After two hours, the controller 1 102 

|* will automatically instruct the heating element controller 1114 to turn off the warming 

I* 

Q 15 plate 1118. The controller 1102 is aware of elapsed time by setting timers in the real- 
ly 

*3 time clock 1112. 

I* 

The coffeemaker 116 may also alternatively be configured from the intelligent 
controller 102 and web device 104. The intelligent controller 102 detects the presence of 
coffeemaker 1 16 when the coffeemaker 1 16 broadcasts a message via the local network 
20 communication unit 1106 upon the coffeemaker 116 being energized (plugged-in to the 
outlet 124). In an alternate embodiment, the intelligent controller 102 periodically checks 
for new appliances, by broadcasting a message to all appliances connected either to the 
power line network or by periodically searching for specific types of appliances, such as 
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coffeemaker 116. In yet another embodiment, registration occurs at a web page 
displayed on the web device 104 that enables the user to enter information into a user 
profile 204, such as selecting an input box associated with the coffeemaker or a serial 
number, that is downloaded to the intelligent controller 102. 

In one potential embodiment, the controller 1102 communicating with the 
intelligent controller 102 via local network communication unit 1106, results in an 
indicator appearing in the display 1110 to show network communication has been 
established. The indicator may occur after a time message has been received by the 
controller 1102 and real-time clock 1112 has been set. The indicator will stay lit for a 
predetermined indicator time even if communication with the intelligent controller 102 is 
lost. After that predetermined indicator time, the "network link established" indicator 
will be deactivated and no longer visible on the display 1110. In an alternate 
embodiment, the indicator will be deactivated upon the controller 1102 losing 
communication via the local network communication unit 1106 with the intelligent 
controller. 

The controller 1102 in the coffeemaker 116 may periodically receive time 
messages from the intelligent controller 102 over the local communication network that 
results in the controller 1102 setting the real-time clock 1112. In an alternate 
embodiment, the controller 1 102 receives a specific time message that is transmitted only 
to the coffeemaker 116. In yet another embodiment, the controller 1102 requests a time 
message from the intelligent controller via the local network communication unit 1106 
when power is initially applied to the coffeemaker 1 16 or restored after a power outage. 
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The controller 1 102 receives programming information from the intelligent 
controller 102 via the local network communication unit 1 106. The intelligent controller 
in turn has obtained the information from the user profile data entered on the coffeemaker 
web page 240. The programming of the coffeemaker 1 16 is by day of week, but in an 
alternate embodiment may be configurable for multiple time events (multiple times a day, 
just not once a day). When the coffeemaker 1 16 is programmed to turn on, the controller 
1 102 preferably stores the information in memory and sets an event to trigger in the real- 
time clock 1112. Because this is local to the coffeemaker, once set even if network 
connection is lost, the coffeemaker 116 can go on. The display 1110 activates a timer 
indicator to show the coffeemaker 1 16 has been programmed. At each programmed day 
and time, the controller 1 102 is notified of the event by real-time clock 1112 and notifies 
the heating element controller 1 1 14 to turn on the heating element 1116 and warming 
plate 1118. After a preset time, the heating element controller 1114 turns off the heating 
element 1116 and the coffee is kept hot by the warming plate 1118. During the coffee 
making operation, the controller 1 102 activates an "on" indicator in display 1110. When 
the heating element controller 1 1 14 turns off the heating element 1116, the controller 
activates a "ready" display on display 1110. 

Preferably, the controller 1 102 sends messages via the local network 
communication unit 1 106 to the intelligent controller 102 when the state of the 
coffeemaker 1 16 changes. When the coffeemaker 1 16 is programmed with times for 
turning on, the controller 1 102 may send a message indicating that the coffeemaker is not 
ready to brew to the intelligent controller 102. A user prepares the coffeemaker 1 16 by 
placing water and coffee grounds in the coffeemaker 116 and by pressing one of the 
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plurality of buttons 1 120 to activate the cofFeemaker 116. The controller 1 102 may send 
a message to the intelligent controller that the cofFeemaker 1 16 has been activated. When 
the programmed time occurs, the cofFeemaker 1 16 is turned on and the coffee starts to 
brew. The controller 1 102 then sends a message to the intelligent controller 102 
5 signifying that the coffee is brewing. When brewing is complete, the controller 1 102 
notifies the intelligent controller 102 by sending a message via the local network 
communication unit 1106. 

After the predetermined hold time (generally two hours) about two hours, the 
heating element controller 1 1 14 is notified over bus 1 104 by the controller 1 102 to turn 
10 off (auto off) the warming plate 1118. The controller 1 102 also deactivates the "on" 
indicator and the "ready" indicator in display 1110. The controller 1 102 also send a 



13 
Q 
Q 

jry message to the intelligent controller 102 to inform the intelligent controller 102 that the 



|l) cofFeemaker 1 16 is again in the not ready to brew. In an alternate embodiment, the 

M< period of time for auto off may be set at a web page and stored in the user profile 204 for 

P 1 5 downloading to the cofFeemaker 1 1 6 via the intelligent controller 1 02. 



BREADMAKER 

Examining FIG. 12, a block diagram of the breadmaker 118 with a local network 
communication link 1206 of FIG. 1 is shown. Local network communication unit 1206 is 
20 preferably a power line communication unit. A controller 1202 is operably connected by 
a bus 204 with the power line communication unit 1206, display 1208, mixer engine and 
controller 1210, memory 1212, an optional product input device such as a bar code reader 
controller 1214 having a bar code reader 1216, plurality of buttons 1217 and heating 
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element controller 1218. The heating element controller 1218 is connected to heating 
element 1220 and controls the cycling of the heating element and heat applied to baking 
dough. The display 1208 is controlled by a display controller 1222 and converts the 
messages received from the controller 1202 into human perceptible graphics, such as 
symbols and letters to form words. 

The controller 1202 is preferably a microprocessor. In an alternate embodiment, 
controller 1202 may be a reduced instruction set chip (RISC) processor, micro-controller, 
digital circuits functioning as a controller, analog circuits functioning as a controller, a 
combination of analog and digital circuits functioning as a controller, or a digital signal 
processor. 

The display 1208 may be preferably able to display text and low-resolution 
graphics. The display is controlled by a display controller 1222 that is in communication 
with memory 1212 and controller 1202. The display 1208 is a liquid crystal non-color 
display. In an alternate embodiment, a high-resolution display may be used. Further, a 
color display may be used in yet another embodiment. Even through a LCD display has 
been used with the preferred embodiment, any other types of displays that are capable of 
displaying data may be used, including cathode ray tubes and plasma displays. The 
display may even be a touch screen that combines the plurality of buttons 1217 with 
display 1208. 

The power line communication unit 1206 is a unit that transmits a carrier signal 
that is capable of transporting data between devices over the traditional home AC wiring 
that electrical appliances receive power from. Thus, the power line communication unit 
1206 is shown as both a power supply for the breadmaker 1 18 and a communication unit 
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that enables two-way communication with the intelligent controller 102 that share the AC 
wiring. Examples of such power line communication approaches include; X-10, CEBUS, 
and POWERBUS by Domosys Corp. Of course other local network interfaces could 
alternatively be used. 

The local network communication unit 1206 enables two-way communication 
from an appliance to another device and the exchange of data including recipe programs 
and time synchronization messages. The two-way communication preferably does not 
occur over a continuous communication path, rather communication occurs between the 
appliance and the intelligent controller 102 and then between the intelligent controller 
102 and the server 104. Similarly, communication may occur between the server 104 and 
the intelligent controller 102, and then between the intelligent controller 102 and 
appliances. In alternate embodiments, a communication may be established between the 
appliance and the server 104 through the intelligent controller 102. 

The memory 1212 is a combination of random access memory (RAM), such as 
dynamic random access memory (DRAM), synchronous dynamic random access memory 
(SDRAM), or other types of read/write memory, and of read only memory (ROM), such 
as programmable read only memory (PROM), electrically erasable programmable read 
only memory (EEPROM). In an alternate embodiment, the memory may include external 
semi-permanent memory, such as magnetic disk (hard disk, removable hard disk, floppy 
disk), optical disk (CD-RW) or external permanent memory (CD-R and DVD-R). The 
memory is 1212 is divided into a program portion that controls the operation of the 
breadmaker 118 and a data portion that maintains configuration data and variables used 
and manipulated by the controller 1202 upon execution of a program. 
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In manual operation, the user may set select the bread type and crust darkness 
using the plurality of buttons 1217. The breadmaker may be turned on or off by one of 
the plurality of buttons 1217. Once turned on, controller 1202 in the breadmaker 118 
executes a default breadmaking recipe program in memory 1212 that instructs the mixer 
engine and controller 1210 heating element controller 1218 to start the bread making 
process that finishes upon the executed default breadmaking program ending. 

The breadmaker may alternatively be configured from the intelligent controller 
102 and device 104. .The intelligent controller 102 detects the presence of breadmaker 
118 when the breadmaker 118 broadcasts a message via the power line communication 
unit 1206 upon being plugged-in to the outlet 126. In an alternate embodiment, the 
intelligent controller 102 periodically checks for new appliances, by broadcasting a 
message to all appliances connected either to the power line network or by periodically 
searching for specific types of appliances, such as breadmaker 118. In yet another 
embodiment, registration occurs at a web page displayed on the web device 104 that 
enables the user to enter information into a user profile 204, such as selecting an input 
box associated with the breadmaker 118 or a serial number, that is downloaded to the 
intelligent controller 102. The breadmaker 118 may also provide some indication of 
network connection. 

The registered breadmaker 118 receives bread making recipe programs from the 
intelligent controller 102 via the local network communication unit. The intelligent 
controller in turn has obtained the information from the data previously selected via web 
page 238. Each of the bread making recipe programs contain a set of instructions for the 
controller 1202 that control the cycles of the breadmaker 118. If no bread making recipe 
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programs are selected, the breadmaker 118 loads default bread making recipe programs 
from the user profile 204 via the intelligent controller 102. The bread making recipe 
program from memory 1212 may preferably be selected by scanning a UPC symbol on a 
pre-mix bread making package using bar code reader 1216. In one preferred 
embodiment, the bar code reader 1216 is shaped like a pen and activates by pressing 
button 1219. An audible signal is generated upon the successful scanning of a unique 
product code, such as a UPC symbol when button 1219 is activated. 

The bar code reader controller 1214 receives the read UPC symbol from the bar 
code reader 1216 and converts the bar code symbol into digital data that is read by the 
controller 1202 over bus 1204. In other embodiments, other types of input may be used 
for identifying a unique product code, including punch cards, magnetic encoded 
information (e.g. magnetic strips), keypad entry or other manual entry. The controller 
1202 then identifies if one of the bread making recipe program in memory is associated 
with the digital data received from the bar code reader controller 1214. 

Upon identifying the bread making recipe program, the controller 1202 then starts 
to execute the selected bread making recipe program. Directions for using the pre-mix 
bread recipe are displayed on display 1208 via display controller 1222. The controller 
1202 executing the bread making recipe program initiates each cycle by instructing the 
mixer engine and controller 1210 along with heating element controller 1218 as to when 
to turn on and off, and heating temperature (warm to raise dough 90 degrees, hot 350 
degrees to bake, and warm 90 degrees to keep bread warm). 

During execution of the bread making recipe program, the breadmaker 1 1 8 may 
count down and display the minutes remaining until the bread is done. In this preferred 



-32- 



approach, the controller 1202 sets a counter that is decrements to track passing of time. 
In an alternate embodiment, a real-time clock 1224 may be in communication with 
controller 1202. The real-time clock 1224 receives time messages from the information 
controller 102, periodically. The real-time clock 1224 then synchronizes to the time 
maintained by the intelligent controller 102. The real-time clock 1224 functions in 
similar fashion to the real-time clock 1 1 12 in coffeemaker 1 16. 

If a unique product code that was scanned or otherwise entered into the system is 
not found in memory 1212 by controller 1202, then the display controller 1222 is 
instructed by the controller 1202 to display "Not in Memory" on display 1208. The user 
manually selects the bread making recipe program to be used with the pre-mix bread. In 
an alternate embodiment, a default bread making recipe program is used with the pre-mix 
bread when the UPC that was scanned is not found in memory 1212. An unknown UPC 
message is formatted by the controller 1202 containing the unknown UPC a sent via the 
power line communication unit 1206 to the intelligent controller 102. Upon the next 
synchronization between the database 202 and the intelligent controller 102, the unknown 
UPC is sent to the web source 104. If the database 202 has a bread making recipe 
program associated with the unknown UPC, then the user profile 204 is updated with the 
bread making recipe program and scheduled for download to the intelligent controller 
102 upon next synchronization. 

In an alternate embodiment, the receipt of an unknown product code message by 
the intelligent controller 102 results in an immediate synchronization with the web 
database 202. If the product code is not be found in the database, then the user profile 
204 is updated with the UPC as a continuing request for a predetermined period (i.e. one 
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month with a maximum limit of twenty unique product codes). If the bread making 
recipe program becomes available during the continuing request predetermined period, 
then the bread making recipe program sent to the breadmaker 118 via the intelligent 
controller 102 over the local network. 

5 

MICROWAVE OVEN 

FIG. 13 is a block diagram of the microwave oven 120 with a local network 
communication unit 1306 of FIG. 1. Local network communication unit 1306 is 
preferably a power line communication unit. In the microwave oven 120, a controller 
□ 10 1302 is operably connected via a bus 1304 to the power line communication unit 1306, a 

5 

P real-time clock 1308, a memory 1310, a plurality of buttons 1312, a display 1314 via a 

}* ' ■ 

!^ display controller 1316, a microwave generator controller 1318, and a product code input 

I' controller unit, such as a bar code reader controller 1324. Examples of other types of 

Ms product code inputs include magnetic media, punch cards, and keypads. The microwave 

I J 

M« 15 generator controller 1318 controls and is coupled to the microwave generator 1320 and a 

P 

carousel engine 1322. 

The controller 1302 is preferably a microprocessor. In an alternate embodiment, 
controller 1302 may be a reduced instruction set chip (RISC) processor, micro-controller, 
digital circuits functioning as a controller, analog circuits functioning as a controller, a 
20 combination of analog and digital circuits functioning as a controller, or a digital signal 
processor. 

The display 1314 is preferably able to display text and low-resolution graphics. 
The display is controlled by a display controller 1316 that is in communication with 
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memory 1310 and controller 1302. The display 1314 may be a liquid crystal non-color 
display. In an alternate embodiment, a high-resolution display may be used. Further, a 
color display may be used in yet another embodiment. Even through a LCD display has 
been used with the preferred embodiment, any other types of displays that are capable of 
5 displaying data may be used, including cathode ray tubes and plasma displays. The 
display may even be a touch screen that combines the plurality of buttons 1312 with 
display 1314. 

The power line communication unit 1306 is a unit that transmits a carrier signal 
that is capable of transporting data between devices over the traditional home AC wiring 

p 10 that electrical appliances receive power from. Thus, the power line communication unit 

§ 

C3 1306 is shown as both a power supply for the microwave oven 120 and a communication 

- unit that enables two-way communication with the intelligent controller 102 that share 

in 

^ the AC wiring. Examples of such power line communication approaches include; X-10, 

5 

j A CEBUS, and POWERBUS by Domosys Corp. Of course other local network interfaces 

S3 

m 1 5 could alternatively be used. 

13 

|;f» The power line communication unit 1306 enables two-way communication from 

an appliance to another device and the exchange of data including recipe programs and 
time synchronization messages. The two-way communication preferably does not occur 
over a continuous communication path, rather communication occurs between the 
20 appliance and the intelligent controller 102 and then between the intelligent controller 
102 and the server 104. Similarly, communication may occur between the server 104 and 
the intelligent controller 102, and then between the intelligent controller 102 and 
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appliances. In alternate embodiments, a communication may be established between the 
appliance and the server 104 through the intelligent controller 102. 

The memory 1310 is a combination of random access memory (RAM), such as 
dynamic random access memory (DRAM), synchronous dynamic random access memory 
(SDRAM), or other types of read/write memory, and of read only memory (ROM), such 
as programmable read only memory (PROM), electrically erasable programmable read 
only memory (EEPROM). In an alternate embodiment, the memory may include external 
semi-permanent memory, such as magnetic disk (hard disk, removable hard disk, floppy 
disk), optical disk (CD-RW) or external permanent memory (CD-R and DVD-R). The 
memory 1310 is divided into a program portion that controls the operation of the 
microwave oven 120 and a data portion that maintains configuration data and variables 
used and manipulated by the controller 1302 upon execution of a program. 

In manual operation, the user may set time and power level or energy setting of 
the microwave oven 120 using the plurality of buttons 1312. The microwave oven may 
be turned on or off by one of the plurality of buttons 1312 and will not start until the 
cooking chamber containing the carousel is closed. Once turned on, controller 1302 in 
the microwave oven 120 is activated at the set power level for the time period set by the 
user. The microwave generator controller 1318 start the oven cooking process that 
finishes upon the expiration of the time period set by the user. The microwave generator 
controller activates the microwave generator 1302 that results in high frequency 
electromagnetic signals that heat items placed in the cooking chamber. The microwave 
generator controller 1318 also activates the carousel engine 1322 that is connected to a 
turntable that rotates items in the cooking chamber and results in a more even distribution 
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of the high frequency electromagnetic signals. Similarly, the real-time clock 1308 that 
generates the time that is displayed in display 1314 may be manually set using the 
plurality of buttons 1312. 

The microwave oven may alternatively be configured from the intelligent 
controller 102 and device 104. The intelligent controller 102 detects the presence of 
microwave oven 120 when the microwave oven 120 broadcasts a message via the power 
line communication unit 1306 upon being plugged-in to the outlet 128. In an alternate 
embodiment, the intelligent controller 102 periodically checks for new appliances, by 
broadcasting a message to all appliances connected either to the power line network or by 
periodically searching for specific types of appliances, such as microwave oven 120. In 
yet another embodiment, registration occurs at a web page displayed on the web device 
104 that enables the user to enter information into a user profile 204, such as selecting an 
input box associated with the microwave oven 120 or a serial number, that is downloaded 
to the intelligent controller 102. The microwave oven may also provide some . indication 
of network connection. 

The registered microwave oven 120 receives microwave oven recipe programs 
from the intelligent controller 102 via the local network communication link. The 
intelligent controller in turn has obtained the information from the data previously 
selected via web page 242. If no microwave oven recipe programs are selected, the 
microwave oven 120 is loaded from defaults microwave oven recipe programs from the 
user profile 204 via the intelligent controller 102. A microwave oven recipe program 
from memory 1310 may preferably be selected by scanning a unique product code, such 
as a UPC symbol on a consumer package (i.e. food container or box) using bar code 
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reader 1326. In one preferred embodiment, the bar code reader 1326 is shaped like a pen 
and activates by pressing button 1328. An audible signal is generated upon the 
successful scanning of the unique product code, such as a UPC symbol when button 1326 
is activated. 

The bar code reader controller 1324. receives the read UPC symbol from the bar 
code reader 1326 and converts the bar code symbol into digital data that is read by the 
controller 1302 over bus 1304. The controller 1302 then identifies if one of the bread 
making recipe program in memory 1310 is associated with the digital data received from 
the bar code reader controller 1324. In other embodiments, the other types of input 
reader controllers may be used that control such things as manual inputs, punch card 
readers, and magnetic media readers, to name but a few. 

Upon identifying the microwave oven recipe program, the controller 1302 then 
execute the microwave oven recipe program. Directions for preparing the consumer item 
are displayed on display 1314 via display controller 1316, and the power level and 
cooking time are programmed. The user may also be prompted for serving sizes and to 
proceed to other steps. The user may respond by using the plurality of buttons 1312 to 
the different prompts on display 1314. The controller 1302 also instructs the microwave 
generator controller 13 18 as to when to turn on, off (cook time), and power level that will 
be used to cook the consumer product that scanned. 

During execution of a microwave oven recipe program, the microwave oven 120 
may count down the remaining minutes until the consumer product is done. In this 
preferred approach the controller 1302 sets a counter in the real-time clock 1308 and 
relays time data to the display controller 1316 that is then shown on display 1314. The 
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real-time clock 1308 receives time messages from the information controller 102, 
periodically. The real-time clock 1308 then synchronizes to the time maintained by the 
intelligent controller 102. The real-time clock 1308 functions in similar fashion to the 
real-time clock 1 1 12 in coffeemaker 116. 

If a UPC that was scanned is not found in memory 1310 by controller 1402, then 
the display controller 1316 is instructed by the controller 1302 to display "Not in 
Memory" on display 1314. The default microwave oven recipe program is then used 
with the consumer product. An unknown UPC message is formatted by the controller 
1302 containing the unknown UPC a sent via the power line communication unit 1306 to 
the intelligent controller 102. Upon the next synchronization between the database 202 
and the intelligent controller 102, the unknown UPC is sent to the web source 104. If the 
database 202 contains a microwave oven recipe program associated with the unknown 
UPC, then the user profile 204 is updated with the microwave oven recipe program and 
scheduled for download to the intelligent controller 102 upon next synchronization. 

In an alternate embodiment, the receipt of an unknown UPC message by the 
intelligent controller 102 results in an immediate synchronization with the web database 
202. If the UPC is not be found in the database, then the user profile 204 is updated with 
the UPC as a continuing request for a predetermined period (i.e. one month with a 
maximum limit of 20 UPCs). If the microwave oven recipe program becomes available 
during the continuing request predetermined period, then the microwave oven recipe 
program is downloaded to microwave oven 120 via the intelligent controller 102. 
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In FIG. 14, a block diagram of the oven 122 with a local network communication 
unit 1406 of FIG. 1 is shown. Local network communication unit 1406 is preferably a 
power line communication unit. In the oven 122, a controller 1402 is operably connected 
via a bus 1404 to the power line communication unit 1406, a real-time clock 1408, a 
memory 1410, a plurality of controls 1412, a display 1414 via a display controller 1416, a 
burner controller 1418, and a optional product code input controller, such as a bar code 
reader controller 1422. Examples of other types of product code input controllers include 
manual input controllers for accepting entered data, magnetic media reader controllers, 
punch card reader controllers, to name but a few. The burner controller 1418 the 
temperature of the oven by controlling the heat generated by a heating element. The term 
oven is used to describe any type of appliance that cooks in an enclosed cavity with heat 
generated by non-microwave means and include for example gas ovens, electric ovens, 
convection ovens, or combinations such as an ultravection oven. The heating element 
may be an electrical heating element or a fossil fuel type burner. The bar code reader 
1422 is connected to a bar code reader 1424 having a button 1426 that activates the bar 
code reader 1422. 

The controller 1402 is preferably a microprocessor. In an alternate embodiment, 
controller 1202 may be a reduced instruction set chip (RISC) processor, micro-controller, 
digital circuits functioning as a controller, analog circuits functioning as a controller, a 
combination of analog and digital circuits functioning as a controller, or a digital signal 
processor. 

The display 1414 is preferably able to display text and low-resolution graphics. 
The display is controlled by a display controller 1416 that is in communication with 
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memory 1410 and controller 1402. The display 1414 may be a liquid crystal non-color 
display. In an alternate embodiment, a high-resolution display may be used. Further, a 
color display may be used in yet another embodiment. Even through a LCD display has 
been used with the preferred embodiment, any other types of displays that are capable of 
5 displaying data may be used, including cathode ray tubes and plasma displays. The 
display may even be a touch screen that combines the plurality of controls 1412 with 
display 1414. 

The power line communication unit 1406 is a unit that transmits a carrier signal 
that is capable of transporting data between devices over the traditional home AC wiring 
Q 10 that electrical appliances receive power from. Thus, the power line communication unit 

9 

13 1406 is shown as both a power supply for the oven 122 and a communication unit that 

jj^ enables two-way communication with the intelligent controller 102 that share the AC 

b\ 

wiring. Examples of such power line communication approaches include; X-10, CEBUS, 
l A and POWERBUS by Domosys Corp. Of course, other local network interfaces could 

C3 

U 15 alternatively be used. 

P 

I* The power line communication unit 1406 enables two-way communication from 

an appliance to another device and the exchange of data including recipe programs and 
time synchronization messages. The two-way communication preferably does not occur 
over a continuous communication path, rather communication occurs between the 
20 appliance and the intelligent controller 102 and then between the intelligent controller 
102 and the server 104. Similarly, communication may occur between the server 104 and 
the intelligent controller 102, and then between the intelligent controller 102 and 
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appliances. In alternate embodiments, a communication may be established between the 
appliance and the server 104 through the intelligent controller 102. 

The memory 1410 is a combination of random access memory (RAM), such as 
dynamic random access memory (DRAM), synchronous dynamic random access memory 
(SDRAM), or other types of read/write memory, and of read only memory (ROM), such 
as programmable read only memory (PROM), electrically erasable programmable read 
only memory (EEPROM). In an alternate embodiment, the memory may include external 
semi-permanent memory, such as magnetic disk (hard disk, removable hard disk, floppy 
disk), optical disk (CD-RW) or external permanent memory (CD-R and DVD-R). The 
memory is 1410 is divided into a program portion that controls the operation of the oven 
122 and a data portion that maintains configuration data and variables used and 
manipulated by the controller 1402 upon execution of a program. 

In manual operation, the user selects an energy setting (temperature) of the oven 
122 using the plurality of controls 1412. The user may also be able to set a time period 
for pre-heating the oven and a cooking time period using the plurality of controls 1412. 
The oven may be turned on by one of the plurality of controls 1412 that selects the 
energy setting. Once turned on, controller 1402 in oven 122 executes a default oven 
recipe program in memory 1410 that instructs the burner controller 1418 to start the 
heating process by activating the heating element 1420. When the oven finishes 
execution of the default oven recipe program the controller 1402 instructs the burner 
controller 1418 to deactivate the heating element 1420 or to keep the oven warm by 
reducing the heat generated by the heating element 1420. The user may also manually set 
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the real-time clock 1404 so time is properly displayed on display 1414 using the plurality 
of controls 1412. 

The oven may alternatively be configured from the intelligent controller 1 02 and 
web device 104. The intelligent controller 102 detects the presence of oven 122 when the 
oven 122 broadcasts a message via the power line communication unit 1406 upon being 
plugged-in to the outlet 130. The oven 122 also receives timing messages that enable the 
controller 1420 to set the real-time clock 1408 and display the correct time on display 
1414. In an alternate embodiment the intelligent controller 102 periodically checks for 
new appliances either by broadcasting a message to all appliances connected to the power 
line network or by periodically searching for specific types of appliances, such as oven 
122. In yet another embodiment, registration occurs at a web page displayed on the web 
device 104 that enables the user to enter information into a user profile 204, such as 
selecting an input box associated with the oven 122 or a serial number, that is 
downloaded to the intelligent controller 102. The oven may also provide some indication 
of network connection. 

The registered oven 122 receives oven recipe programs from the intelligent 
controller 102 via the local network communication link. The intelligent controller in 
turn has obtained the information from the data previously selected via web page 236. If 
no oven recipes are selected, the oven 122 is loaded from defaults oven recipes from the 
user profile 204 via the intelligent controller 102. The oven recipe program from 
memory 1410 may preferably be selected by scanning a unique product code, such as a 
UPC symbol on a consumer package (i.e. food container or box) using bar code reader 
1424. In one preferred embodiment, the bar code reader 1424 is shaped like a pen and 
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activates by pressing button 1426. An audible signal is generated upon the successful 
scanning of a UPC symbol when button 1426 is activated. 

The bar code reader controller 1422 receives the read UPC symbol from the bar 
code reader 1424 and converts the bar code symbol into digital data that is read by the 
controller 1402 over bus 1404. The controller 1402 then identifies if a oven recipe 
program that is associated with the digital data received from the bar code reader 
controller 1422. In alternate embodiments, other types of product code reader controllers 
may be used, such as manual input controllers, punch card controllers, magnetic media 
reader controllers, to name but a few. 

Upon identifying the microwave oven recipe program, the controller 1402 then 
starts to execute the oven recipe program. Directions for use of the oven recipe program 
are displayed on display 1414 via display controller 1416. The user may also be 
prompted for serving sizes and to proceed in the preparation of the scanned consumer 
product. The user may respond to such by using the plurality of controls 1412. The 
controller 1402 also instructs the burner controller 1418 as to when to turn on and off, 
and what temperature is required to cook the consumer product that was previously 
scanned. 

During execution of a program associated with the selected oven recipe program, 
the oven 122 may count down and display the remaining minutes until the consumer 
product is done. The controller 1402 sets a counter in the real-time clock 1408 and relays 
time data to the display controller 1416 that is then shown on display 1414. The real- 
time clock 1408 receives time messages from the information controller 102, 
periodically. The real-time clock 1408 then synchronizes to the time maintained by the 
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intelligent controller 102. The real-time clock 1408 functions in similar fashion to the 
real-time clock 1 1 12 in coffeemaker 116. 

If a UPC that was scanned is not found in memory 1410 by controller 1402, then 
the display controller 1416 is instructed by the controller 1402 to display "Not in 
Memory" on display 1414. The default oven recipe program is then used with the 
consumer product or the user is prompted to manual set the oven 122. An unknown 
unique product code message is formatted by the controller 1402 containing the unknown 
unique product code, such as a UPC and sent via the power line communication unit 1406 
to the intelligent controller 102. Upon the next synchronization between the database 202 
and the intelligent controller 102, the unknown UPC is sent to the web source 104. If the 
database 202 contains a recipe associated with the unknown UPC, then the user profile 
204 is updated with the oven recipe program and scheduled for download to the 
intelligent controller 102 upon next synchronization. In an alternate embodiment, the 
receipt of an unknown UPC message by the intelligent controller 102 results in an 
immediate synchronization with the web database 202. If the UPC is not be found in the 
database, then the user profile 204 is updated with the UPC as a continuing request for a 
predetermined period (i.e. one month with a maximum limit of 20 UPCs). If the oven 
recipe program becomes available during the continuing request predetermined period, 
then the oven recipe program is downloaded to the oven 122 via the intelligent controller 
102. 

FLOW CHARTS 
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Turning to FIG. 15, a flow chart of an intelligent kitchen process is shown. The 
process starts (1502) and the user access a graphical interface (1504) to configure a user 
profile 204. The graphical interface may be a web page, a text only interface, a text 
displayed in graphical form, such as a bit mapped character set, a combination of text and 
graphical information. The graphical interface may be multiple screens such as multiple 
web pages with each screen requiring data to be entered (1506) by selecting items, 
inputting data or both selecting and inputting. In other embodiments, one screen is 
presented with data being inputted, selected or both inputted and selected in the one 
screen. The plurality of data that is inputted and selected by the user via the graphical 
interface is stored (1508) in a user profile 204 in a database 202. 

To facilitate the use of slower modem, the intelligent controller 102 is preferably 
configured to initiate contact with the remote database in the middle of the night. 
Alternatively, the user may force the connection. During this connection, the intelligent 
controller 102 receives the plurality of data (1510) from the user profile over a first 
network, such as PSTN network 110. The intelligent controller 102 may also receive a 
time synchronization message (1512) from a server, such as web server 100. The correct 
time is then displayed (1514) on the display 218 of intelligent controller 102. The time 
zone that the intelligent controller 102 is located in is contained in the plurality of data 
that is stored in the user profile 204, now received by the intelligent controller. 

A check is made at the intelligent controller 102 to determine if a microwave oven 
120 is accessible or connected to the home network (1516). The home network is a local 
communication network, such as a power line communication network using a home's 
AC wiring. In an alternate embodiment, the home network may be a wireless RF 
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network, a two-wire network, or some combination of wired and wireless network. If the 
microwave oven is accessible, then a portion of the data from the plurality of data for the 
microwave oven is downloaded from the intelligent controller 102 to the microwave oven 
120 and stored in memory 1310. The real-time clock 1308 in the microwave oven 120 
5 may also be synchronized (1520) to the correct time by transmitting a time message over 
the home network from the intelligent controller 102. 

A check is then made to determine if an oven 122 is connected to the home 
network (1522). If the oven is accessible, then a portion of data from the plurality of data 
for the oven is transmitted from the intelligent controller 102 to the oven 122 (1524) and 

10 stored in memory 1410 associated with the oven. The real-time clock 1408 in the oven 
122 may also be synchronized (1526) to the correct time by transmitting a time message 
over the home network from the intelligent controller 102. A check is then made to 
determine if a breadmaker 118 is connected to the home network (1528). If the 
breadmaker 118 is accessible, then a portion of data from the plurality of data for the 

15 microwave oven is downloaded from the intelligent controller 102 to the breadmaker 118 
(1530) and stored in memory 1212 associated with the breadmaker . The real-time clock 
1224 in the breadmaker 118 may be synchronized (1532) to the correct time by receiving 
a time message over the home network from the intelligent controller 102. 

A check is then made to determine if a coffeemaker 1 16 is connected to the home 

20 network (1534). If a coffeemaker is connected to the home network (1534), then a 
portion of data from the plurality of data for the coffeemaker 1 16 is transmitted from the 
intelligent controller 102 to the coffeemaker 116 and stored in memory 1108 (1536) 
associated with the coffeemaker. The portion of data configures the brew time of the 
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coffeemaker, i.e. when the coffeemaker turns on. The state of the coffeemaker is set 
(1538) and transmitted to the intelligent controller 102. The possible states are for 
example "ready to brew", "brewing" and "ready." The real-time clock 1112 in the 
coffeemaker 116 may be synchronized (1540) to the correct time by receiving a time 
message over the home network from the intelligent controller 102. Processing for 
configuring an intelligent kitchen would continue for any additional intelligent appliances 
until complete (1542). 

In FIG. 16, a flow chart of the process of the intelligent controller 102 interacting 
with the coffeemaker 116 is shown. Assuming the real-time clock 1112 has previously 
been set, the process starts (1602) by determining if the timer in the coffeemaker 116 is 
set (1604). If the timer in the coffeemaker 1 16 is set, then the state of the coffeemaker 
116 is set to "not ready to brew" (1606) and the state information is transmitted to the 
intelligent controller 102 (1608) via the power line communication unit 1106. The 
intelligent controller 102 then preferably displays the state of the coffeemaker on the 
intelligent controller's display 218. 

In order for the coffeemaker 1 16 to become ready to brew, a user must put a filter, 
coffee grounds and water into the coffeemaker 116. Once everything is ready, the user 
presses one of the plurality of buttons 1 120 to indicate that the coffeemaker 1 16 is ready 
to brew (1610). The coffeemaker will not change states unless it is activated by the user, 
alternatively, one or more sensors in the coffeemaker may determine when the coffee 
filter, coffee grounds and water are present in the coffeemaker 116 and everything is 
ready for brewing coffee. 
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When the user activates the coffeemaker 116, the state of the coffeemaker 1 16 is 
changed from "not ready to brew" to "ready to brew" (1612). The coffeemaker 1 16 via 
the power line communication unit 1106 sends the new state of "ready to brew" to the 
intelligent controller 102 (1614). The active coffeemaker 116, then waits until it is time 
to turn on or brew coffee (1616). If it is not time to turn on, then the coffeemaker 
continues to wait and check if it is time to turn on (1616). 

If it is time to turn on (1616), then the coffeemaker 116 is turned on by its 
controller 1 102 and the state of the coffeemaker is set to "brew" (1618). The new state is 
transmitted to the intelligent controller 102 (1620) and the new state preferably appears 
on the intelligent controller's display 218. Coffee is then brewed by the coffeemaker 1 16 
(1622) as known in the art. The coffee is brewed for a predetermined amount of time 
until it is finished brewing (1624), usually for an amount of time to ensure the water has 
been heated and passed through the filter and coffee grounds. If the coffee is finished 
brewing (1624), then the state of the coffeemaker is set to "ready" in order to indicate 
that coffee is ready to be served. The heating element 1116 in the coffeemaker 116 is 
turned off by the heating element controller 1 1 14 and the warming plate 1118 is kept on 
for a predetermined time period, typically one hour. The coffeemaker 1 16 transmits the 
new state to the intelligent controller 116 over the home network via the power line 
communication unit 1 106 (1628). After the expiration of the predetermined time period, 
the warming plate 1118 is turned off along with the coffeemaker 116 (1630) and step 
(1640) is repeated. If no timers are set in the coffeemaker (1640) then processing ends 
(1632). 



-49- 



Examining FIG. 17, a flow chart of the process of programming a household 
appliance using a unique product code is shown. The process starts (1702) by scanning a 
unique product code, such as a bar code, (UPC) associated with a consumer package 
(1704). A bar code reader controller then converts the scanned bar code into a digital 
signal (1706). Alternatively, the digital signal may be generate by the user manually 
inputting the product code (1707). The digital signal is then used to access recipe 
programs stored in memory. If the digital signal is associated with a recipe program in 
the memory of the appliance (1708), then the appliance is configured according to the 
recipe program (1710), i.e. time and temperature of a oven or microwave oven is set and 
processing is complete (1712). 

If the digital signal is not associated with a recipe program in the memory of the 
appliance (1708), then the digital signal is sent by the home network to the intelligent 
controller 102 (1714). In a preferred embodiment, the intelligent controller 102 waits for 
its next scheduled communication with the user profile and sends the digital signal to the 
user profile over the first network (PSTN) 110 (1716). Alternatively, the user may 
prompt the system to immediately contact the server 104 to check for the recipe program. 
Further, prompting of the system to immediately contact the server may be a configurable 
option in other embodiments. The database 202 is then searched to determine if the 
digital signal is associated with a recipe (1718). If a recipe program is found that is 
associated with the digital signal (1718), then the recipe program is sent to the intelligent 
controller 102 (1720) over the first network and the user profile is updated to identify the 
recipe program. The recipe program is then sent from the intelligent controller 102 to the 
household appliance over the home network (1722). The appliance is then configured 
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according the recipe program (1710). In an alternate embodiment, the recipe may not be 
able to be retrieved in time to configure the appliance, so the user may manually 
configure the appliance and processing stops (1712). Upon the next scanning of the code, 
the appliance will be configured according to the recipe program. 

If the digital signal is not associated with a recipe program in database 202 
(1718), then the digital signal is stored in the user profile 204 (1724). Periodically the 
digital signals in the user profile that do not have assigned recipe programs are processed 
to see if that recipe program is now available (1726). The processing may be 
configurable to occur daily, weekly, or even monthly. If the recipe program is not 
available (1728), then processing waits until another periodic check occurs (1726). If the 
recipe program does exist, then the recipe is sent to the intelligent controller 102 (1720) 
over the first network. The intelligent controller 102 then sends the recipe program to the 
appliance (1722) where it is stored in the memory of the appliance and processing stops. 

It is appreciated by those skilled in the art that the process shown in FIGs. 15,16 
and 17 may selectively be implemented in hardware, software, or a combination of 
hardware and software. An embodiment of the process steps employs at least one 
machine-readable signal-bearing medium. Examples of machine-readable signal-bearing 
mediums include computer-readable mediums such as a magnetic storage medium (i.e. 
floppy disks, or optical storage such as compact disk (CD) or digital video disk (DVD)), 
a biological storage medium, or an atomic storage medium, a discrete logic circuit(s) 
having logic gates for implementing logic functions upon data signals, an application 
specific integrated circuit having appropriate logic gates, a programmable gate array(s) 
(PGA), a field programmable gate array (FPGA), a random access memory device 
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(RAM), read only memory device (ROM), electronic programmable random access 
memory (EPROM), or equivalent. Note that the computer-readable medium could even 
be paper or another suitable medium, upon which the computer instruction is printed, as 
the program can be electronically captured, via for instance optical scanning of the paper 
or other medium, then compiled, interpreted or otherwise processed in a suitable manner 
if necessary, and then stored in a computer memory. 

Additionally, machine-readable signal bearing medium includes computer- 
readable signal bearing mediums. Computer-readable signal bearing mediums have a 
modulated carrier signal transmitted over one or more wire based, wireless or fiber optic 
networks or within a system. For example, one or more wire based, wireless or fiber 
optic network, such as the telephone network, a local area network, the Internet, or a 
wireless network having a component of a computer-readable signal residing or passing 
through the network. The computer readable signal is a representation of one or more 
machine instructions written in or implemented with any number of programming 
languages. 

Furthermore, the multiple process steps implemented with a programming 
language, which comprises an ordered listing of executable instructions for implementing 
logical functions, can be embodied in any machine-readable signal bearing medium for 
use by or in connection with an instruction execution system, apparatus, or device, such 
as a computer-based system, controller-containing system having a processor, 
microprocessor, digital signal processor, discrete logic circuit functioning as a controller, 
or other system that can fetch the instructions from the instruction execution system, 
apparatus, or device and execute the instructions. 
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While various embodiments of the application have been described, it will be 
apparent to those of ordinary skill in the art that many more embodiments and 
implementations are possible that are within the scope of this invention. Accordingly, the 
invention is not to be restricted except in light of the attached claims and their 
equivalents. 
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